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The present invention relates to computer systems and more particularly to 
enabling communication between two integrated circuits, including, for example, a 
processor and a controller, using high and low power buses. 
BACKGROUND 

5 Computer systems are becoming increasingly pervasive in our society, 

including everything from small handheld electronic devices, such as personal data 
assistants and cellular phones, to application-specific electronic components, such 
as set-top boxes and other consumer electronics, to medium-sized mobile and 
|,& deslctop systems to large workstations and servers. Computer systems typically 
^10 include one or more processors. A processor manipulates and controls the flow of 

Q data in a computer by executing instructions. To provide more powerful computer 

C5 ' 

pj power consumed by the processor tends to increase as well. Historically, the power 

■ 

p 1 5 consumed by a computer system has been limited by two factors. First, as power 
consumption increases, the computer tends to run hotter, leading to thermal 
dissipation problems. Second, the power consumed by a computer system may tax 
the limits of the power supply used to keep the system operational, reducing battery 
life in mobile systems and diminishing reliability while increasing cost in larger 
20 systems. 

One way to reduce the power consumed by the processor is to enable the 
processor to operate in different power states or modes. Generally, when a 
processor is in a high power mode, the processor consumes more power than when 



systems for consumers, processor designers strive to continually increase the 
operating speed of the processor. Unfortunately, as processor speed increases, the 
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the processor is in a low power mode. Therefore, increasing the relative amount of 
time a processor spends in a low power mode reduces the overall power consumed 
by the computer system. 

Unfortunately, some low power modes do not support snooping of one or 
more caches of a processor. This may limit the usefulness of the low power mode 
and force the processor to spend more time in a high power mode, increasing power 
consumption of the computer system. The present invention addresses this and 
other problems associated with the prior art. 



t 10 BRIEF DESCRIPTION OF THE DRAWINGS 

15- 

51 . 



The present invention is illustrated by way of example and not limitation in the 
accompanying figures in which like references indicate similar elements and in 



rj which: 



Figure 1 includes a computer system formed in accordance with an 
15 embodimentof the present invention; 

Figure 2 includes circuits formed in accordance with an embodiment of the 
present invention; and 

Figure 3 includes a flow chart showing a method of the present invention. 

20 DETAILED DESCRIPTION 

In accordance with an embodiment of the present invention, a processor may 
operate in at least two different modes, a high power mode and a low power mode. 
While in the high power mode, the processor may communicate with a controller via 
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a high power bus. When a peripheral device performs a memory access, the 
address of that access may be provided by the controller to the processor via the 
high power bus to snoop processor's cache. 

When the processor transitions into a low power mode, the high power bus 
may be powered down, thereby reducing power consumption of the processor. 
During this low power mode, when a peripheral device performs a memory access, 
the address of that access may be provided by the controller to the processor via a 
low power bus to snoop the processor's cache. Enabling snooping of the 
processor's cache via the low power bus while the processor is in a low power mode 
reduces the need for the processor to transition back to the high power mode to 
service the snoop. Thus, power consumption is reduced. 

A more detailed description of embodiments of the present invention, 
including various configurations and implementations, is provided below. 

As used herein, the tenns "high power" and "low power" are relative 
indications of the power state of a device. A device in a high power mode may 
generally consume more power, on average, than the same device in a low power 
mode. High power modes may altemately be referred to as wake states, execution 
states, processing states, etc. Low power modes may alternately be referred to as 
sleep states, idle states, power-down states, etc. 

Figure 1 includes a computer system formed in accordance with an 
embodiment of the present invention. Power supply 175 supplies a voltage to 
processor 100 and to controller 155. Processor 100 includes clock interface 1 10 
that receives a clock signal from clock generator 180 via one or more clock signal 



-Page 4 of 23- 



P10720JKP.DOC 



lines, and clock interface 110 distributes the clocl< signal internally to various 
components within processor 1 00. For example, clock interface 110 may distribute 
the clock signal to the processor core 130, to cache 105 (via multiplexer 125) and to 
high power bus interface 115. Clock interface 1 10 may include one or more phase- 
locked loops (PLLs) to condition the incoming clock signal from clock generator 180. 
In addition, one or more PLLs within clock interface 110 may increase (multiply) or 
decrease (divide) the frequency of the incoming clock signal from clock generator 
180 before providing the clock signal to other components of processor 100. Clock 
interface 110 may provide the clock signal at different frequencies to different 
components of processor 100. 

Core 130 of processor 100 of Figure 1 may include, for example, one or more 
execution units and registers to execute instructions. Core 130 receives its clock 
signal from clock generator 180 via a clock signal line to clock interface 1 10 of 
processor 100, Core 130 is coupled to cache 105 to store and access data. Core 
130 is further coupled to high power bus interface 1 15 of processor 100 through 
which processor 110 may communicate with controller 1 55. High power bus 
interface 115 may also receives its clock signal from clock generator 180 via a clock 
signal line to clock interface 1 10 of processor 100. 

Note that although only a single cache is shown in processor 100 of Figure 1, 
processor 100 may include additional caches. For example, processor 100 may 
include separate LO, LI , and L2 caches, etc. During a high power mode of 
operation (to be described in more detail below), cache 105 may receive its clock 
signal from clock generator 180 via a clock signal line to clock interface 110, routed 
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through multiplexer 125. During a low power mode of operation (to be described in 
more detail below), cache 105 may receive its clocl< signal from clock generator 180 
via a clock signal line to clock Interface 160 of controller 155, provided to the low 
power bus interface 120 of processor 100 via low power bus 150, and routed 
through multiplexer 125. Cache 105 is further coupled to low power bus interface 
120 to support access of cache 105 during a low power mode of operation (to be 
described in more detail below). 

Controller 155 of Figure 1 includes clock interface 160 that receives a clock 
signal from clock generator 180 via one or more clock signal lines, and clock 
interface 160 distributes the clock signal intemally to various components within 
controller 1 55. For example, clock interface 1 60 may distribute the clock signal to 
high power bus interface 135, to low power bus interface 140, and to memory bus 
interface 185 of controller 1 55. Clock interface 1 60, like clock interface 1 1 0, may 
include one or more phase-locked loops (PLLs) to condition the incoming clock 
signal from clock generator 180. In addition, one or more PLLs within clock 
interface 160 may increase or decrease the frequency of the incoming clock signal 
from clock generator 180 before providing the clock signal to other components of 
controller 1 55. Clock interface 160 may provide the clock signal at different 
frequencies to different components of controller 155. 

The clock signal may be provided to high power bus interface 115 and to high 
power bus interface 135 to synchronize the communication between controller 155 
and processor 100 via high power bus 145 of Figure 1 . In accordance with some 
embodiments of the present invention, high power bus 145 may alternately be 
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referred to as a front side bus, a processor bus, a primary bus, or a system bus. 
The clock signal may also be provided to low power bus interface 140 to 
synchronize the communication between controller 155 and processor 100 via low 
power bus 150. Low power bus interfaces 120 and 140, along with low power bus 
5 150, are described in more detail below in conjunction with Figure 2. 

In accordance with one embodiment of the present invention, high power bus 
145 is wider than low power bus 1 50, allowing high power bus 145 to communicate 
more bits per clock cycle than low power bus 150 of Figure 1. Because low power 
!»* bus 1 50 may be narrower than high power bus 1 45, low power bus 1 50 may operate 
O 1 0 serially in comparison to high power bus 145 which may operate in a more parallel 
^ manner. In addition, in accordance with one embodiment of the present invention, 
ij high power bus 145 may consume more power, on average, than low power bus 
1 50. In other words, in accordance with this embodiment of the present invention, 

hi 

PJ high power bus interfaces 115 and 135 may consume more power, on average, 

m 

O 15 when communicating via high power bus 145 than low power bus interfaces 120 
and 140 may consume when communicating via low power bus 150. 

In accordance with these and other embodiments of the present invention, 
high power bus 145 may communicate at a higher clock frequency than low power 
bus 150. In accordance with one embodiment of the present invention, low power 
20 bus 1 50 may operate as a source-synchronous bus, synchronized to a clock signal 
from controller 155. For one embodiment, high power bus 145 may lack support for 
source-synchronous operation. For this embodiment, high power bus interface 115 
niay be synchronized to high power bus interface 1 35, for communication via high 
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power bus 145, via separate clock signals from clock interfaces 110 and 160, 
respectively. 

Controller 1 55 of Figure 1 is additionally coupled to memory 1 65 and to 
peripheral device 170. Note that in accordance with some computer architectures, 
5 peripheral device 1 70 may be coupled to controller 1 55 via one or more additional 
bus Interfaces, bus-to-bus bridges, hubs, or other controllers. In accordance with an 
embodiment of the present invention, peripheral device 170 may be a device having 
bus mastering capability with read or write access to memory 165 via controller 155. 
p in accordance with an embodiment of the present invention, peripheral device 1 70 

^ 10 may be a magnetic storage device such as a hard drive, an optical storage device 

P ■ 



C3 



such as a digital video disc (DVD) drive, an audio device, a video device such as a 
graphics device, other user input/output device, a network interface, wireless 



communications port, etc. In accordance with one embodiment of the present 
03 invention, memory 165 may be the main memory of a computer system. 

cr 

1=* 15 In accordance with one embodiment of the present invention, controller 1 55 

of Figure 1 may represent a single or multiple hubs or bridges to allow devices of 
different bus architectures to communicate with each other. For example, controller 
155 may be a memory controller hub. In accordance with one embodiment of the 
present invention, controller 155 may be referred to as a north bridge. In addition, 
20 controller 1 55 may be implemented as a single integrated circuit or distributed 
across multiple Integrated circuits. 

SImilariy, processor 100 of Figure 1 may be implemented as a single 
integrated circuit or distributed across multiple Integrated circuits. For example, for 
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one embodiment of the present invention, all or a portion of cache 105 may reside in 
a separate integrated circuit, extemal to processor 100. In addition, in accordance 
with an alternate embodiment of the present invention, additional processors or 
controllers may be coupled to high power bus 145 and to low power bus 150, each 
having high and low power bus interfaces. An embodiment of the present invention 
may be implemented on integrated circuits other than processor 100 and controller 
155. For example, an embodiment of the present invention may be implemented by 
and between two controllers, such as a hub and a graphics controller, or by and 
between two processors. 

In accordance with one embodiment of the present invention, to eliminate 
some circuit redundancy and pin count, low power bus 150 may be, at least in part, 
a subset of high power bus 145 of Figure 1 . In other words, some or all of the signal 
lines of low power bus 150 may double as signal lines of high power bus 145. In 
accordance with this embodiment, some or all of the circuitry of low power bus 
interfaces 120 and 140 may be subsumed within high power bus interfaces 115 and 
1 35, respectively. 

Figure 2 provides a more detailed look at low power bus interfaces 120 and 
140 of Figure 1 , as well as low power bus 150. As shown, in accordance with one 
embodiment of the present invention, low power bus 150 may include a clock signal 
line 151, a control signal line 152, and a data line 153. Clock port 121 of low power 
bus interface 120 is coupled to clock port 141 of low power bus interface 140 via 
clock signal line 151 . Control port 122 of low power bus interface 120 is coupled to 
control port 142 of low power bus interface 140 via control signal line 152. Data port 
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123 of low power bus interface 120 is coupled to data port 143 of low power bus 
interface 140 via data line 153. 

In accordance with one embodiment of the present invention, during 
operation of low power bus 1 50 of Figure 2, a clock signal may be sent from clock 
port 141 of low power bus interface 140 of controller 155 to clock port 121 of low 
power bus interface 120 of processor 100. This clock signal may be used to 
synchronize the transfer of data transferred between low power bus interfaces 120 
and 140 across low power bus 150. The clock signal originates at clock generator 
180, is provided to clock interface 160 of controller 155 via a clock signal line, and 
clock interface 160 then provides the clock signal to low power bus interface 140. 
The clock signal is provided to PLL 124 from clock port 121 of low power bus 
interface 120. PLL 124 may increase or decrease the frequency of this clock signal 
before sending the signal on to the cache of processor 1 00. In addition, the clock 
signal is provided to shift register 126 to time the operation of the shift register. 

Note that in accordance with an alternate embodiment of the present 
invention, the clock signal may be increased or decreased by a PLL before being 
provided to the shift register. Alternatively, the clock signal may be sent at the same 
frequency at which it is received via clock signal line 151 of low power bus 150 of 
Figure 2. For one embodiment of the present invention, low power bus Interface 
140 may also include one or more PLLs to increase or decrease the frequency of 
the clock signal received from clock interface 160 before providing the clock signal 
to processor 100 via clock signal line 151 of low power bus 150. 
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During operation of low power bus 150 of Figure 2, a control signal may be 
sent between control port 142 of low power bus interface 140 and control port 122 of 
low power bus interface 120. Tliis control signal may be used to synchronize 
streams of data transferred between low power bus interfaces 120 and 140 across 
low power bus 150. The control signal may be provided to shift register 126 from 
control port 122. 

In accordance with one embodiment of the present invention, during 
operation of low power bus 150 of Figure 2, data may be sent between data port 
143 of low power bus interface 140 and data port 123 of low power bus interface 
120. In accordance with one embodiment of the present invention, data line 153 
may be one of two or more data lines of low power bus 1 50. For another 
embodiment of the present invention, data line 153 is the only data line of low power 
bus 150. For this embodiment, low power bus 150 may be a three wire bus, 
including clock signal line 151, control signal line 152, and data line 153. Data may 
be provided to shift register 126 from data port 123. 

In accordance with one embodiment of the present invention, data may be 
serialized by low power bus interface 140 before being transferred to low power bus 
interface 120 via low power bus 150 of Figure 2. In accordance with one 
embodiment of the present invention, this data may be serialized by a shift register 
or multiplexer (not shown) of low power bus interface 140. To convert the serialized 
data back to its original width, or to a width that may be useful for internal routing by 
processor 100, shift register 126 may be used to reassemble data. Alternatively, a 
demultiplexer may be used to reassemble the data to the desired width. 
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Similariy, In accordance with one embodiment of the present invention, data 
may be serialized by low power bus interface 120 before being transferred to low 
power bus interface 140 via low power bus 150 of Figure 2. In accordance with one 
embodiment of the present invention, this data may be serialized by a shift register 
or multiplexer (not shown) of low power bus interface 120. To convert the serialized 
data back to its original width, or to a width that may be useful for routing by 
controller 155, a shift register or demultiplexer (not shown) within low power bus 
interface 140 may be used to reassemble data. 

Figure 3 includes a flow chart showing a method of the present invention and 
will be described below in conjunction with the Figures 1 and 2, described above. At 
step 300, processor 100 is triggered to enter a low power mode. This trigger may 
be a signal sent to the processor from an external device. Alternatively, the trigger 
may be a signal generated intemal to the processor in response to executing a 
particular instmction. 

At step 310 of Figure 3, a clock is deactivated and the high power bus is 
powered down, placing the processor in a low power mode. In accordance with one 
embodiment of the present invention, the clock deactivated at step 310 may include 
stopping one or more clock signals emanating from clock interface 1 10 to one or 
more other components of processor 100. These other components may include, 
for example, processor core 130, cache 105, and high power bus interface 115. For 
one embodiment of the present invention, the clock signal sent from clock generator 
180 to processor 100 is stopped. In addition to deactivating one or more clock 
signals and the high power bus, in accordance with one embodiment of the present 
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invention, one or more caches of processor 100 may be fluslied. For example, an 
L1 cache may be flushed to an L2 cache. Alternatively, an LO cache may be flushed 
to an L1 , or both LO and L1 caches may be flushed to an L2 cache. 

In accordance with one embodiment of the present invention, powering down 
5 high power bus 145 at step 310 may include not only stopping the clock provided to 
high power bus interface 1 1 5 from clock interface 110 of processor ICQ but also 
stopping the clock provided to high power bus interface 135 from clock interface 160 
of controller 155. In addition, in accordance with one embodiment of the present 
|,* invention, powering down high power bus 145 at step 31 0 may include turning off 

r% 

C| 1 0 sense amps, input/output buffers, voltage clamps and other power consuming 
|J devices within high power bus interfaces 1 1 5 and 1 35. 

If In accordance with one embodiment of the present invention, cache 105 of 

Figure 1 , which is nonnally accessible via high power bus 145 when processor 100 

W 

pj is in a high power mode, is inaccessible via high power bus 145 when processor 

CJ 

p 1 5 1 00 is in a low power mode. In particular, snooping cache 1 05, which is nomially 
supported via high power bus 145 when processor 100 is in a high power mode, is 
not supported via high power bus 145 when processor 100 Is in a low power mode. 

At step 320, peripheral device 1 70 requests an access of memory 1 65 via 
controller 155. This access may be, for example, a memory read or write. In 
20 accordance with one embodiment of the present invention, to maintain coherency 
with cache 1 05 of processor 1 00, controller 1 55 snoops cache 1 05 without requiring 
processor 1 00 to re-enter a high power mode, as described in steps 330 - 350 
below. 



-Page 13 of 23- 



P10720_AP.DOC 



At step 330, a clock signal may be sent from controller 1 55 to processor 1 00 
via clock signal line 151 of low power bus 150. This clock signal may be provided to 
cache 105 via multiplexer 125 to provide access to cache 105. Thus access to 
cache 105 may be enabled notwithstanding the fact that the normal clock signal 
from clock interface 1 10 to cache 105 may be stopped while processor 100 is in a 
low power mode. 

In accordance with one embodiment of the present invention, the clock signal 
provided to cache 105 via low power bus interface 120 during the low power mode 
of operation may be a different frequency than the clock signal provided to cache 
105 via clock interface 110 during the high power mode of operation. For example, 
the clock signal provided to cache 105 via low power bus interface 120 during the 
low power mode of operation may be a lower frequency than the clock signal 
provided via clock interface 110. In accordance with this embodiment of the present 
invention, because the clock frequency provided to cache 105 is lower during the 
low power mode of operation, the voltage provided to processor 100 by power 
supply 175 may be lower during the low power mode of operation. In this manner, 
the power consumed by processor 100 may be further reduced during the low power 
mode of operation. 

In accordance with one embodiment of the present invention, at step 340 of 
Figure 3 a snoop request is sent from the controller to the processor via the low 
power bus. This snoop request may include the target address of the memory 
access of the peripheral device. This address may be sent to the processor via data 
line 153, alone or in addition to one or more other data lines, of low power bus 150. 
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This address may then be sent to cache 1 05 to determine if data associated with the 
same address is stored in the cache. In accordance with one embodiment of the 
present Invention, this address may be initially sent to the tag array portion of cache 
105, and If a hit is detected in the tag array, the address may be sent to the data 
5 array portion of the cache. In accordance with one embodiment of the present 
Invention, this address may multiplexed onto the same address signal lines that 
couple core 130 to cache 105. 

At step 350 of Figure 3, a snoop response is then sent from cache 1 05 of 
1,4 processor 1 00 to controller 1 55 via low power bus interfaces 1 20 and 140 and low 
CJ 10 power bus 150. This response may be sent via data line 153, alone or in addition to 
G one or more other data lines, of low power bus 1 50. 

m 

This Invention has been described with reference to specific exemplary 
embodiments thereof. It will, however, be evident to persons having the benefit of 

W 

m. this disclosure that various modifications and changes may be made to these 

C3 - , 

O 1 5 embodiments without departing from the broader spirit and scope of the invention. 
The specification and drawings are, accordingly, to be regarded in an illustrative 
rather than a restrictive sense. 
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